package com.sky.mapper;

import com.sky.Entity.AddressBook;
import org.apache.ibatis.annotations.*;

import java.util.List;

@Mapper
public interface AddressBookMapper {

    @Insert("insert into address_book(user_id, consignee, sex, phone, province_code, province_name, " +
            "city_code, city_name, district_code, district_name, detail, label, is_default) values (" +
            "#{userId},#{consignee},#{sex},#{phone},#{provinceCode},#{provinceName}," +
            "#{cityCode},#{cityName},#{districtCode},#{districtName},#{detail},#{label},#{isDefault}" +
            ")")
    void insert(AddressBook addressBook);

    @Select("select * from address_book where user_id=#{userId}")
    List<AddressBook> queryByUserId(Long userId);

    @Select("select * from address_book where user_id=#{userId} and is_default=1")
    AddressBook queryUserDefaultAddress(Long userId);

    void update(AddressBook addressBook);

    @Delete("delete from address_book where id=#{id}")
    void deletById(Long id);

    @Select("select * from address_book where id=#{id}")
    AddressBook queryById(Long id);

    @Update("update address_book set is_default=0 where user_id=#{userId}")
    void updateDefaultByUserId(Long userId);
}
